package com.sky.shortlink.project.service;

import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.service.IService;
import com.sky.shortlink.project.dao.entity.ShortLinkDO;
import com.sky.shortlink.project.dto.biz.ShortLinkStatsRecordDTO;
import com.sky.shortlink.project.dto.req.ShortLinkBatchCreateReqDTO;
import com.sky.shortlink.project.dto.req.ShortLinkCreateReqDTO;
import com.sky.shortlink.project.dto.req.ShortLinkPageReqDTO;
import com.sky.shortlink.project.dto.req.ShortLinkUpdateReqDTO;
import com.sky.shortlink.project.dto.resp.ShortLinkBatchCreateRespDTO;
import com.sky.shortlink.project.dto.resp.ShortLinkCreateRespDTO;
import com.sky.shortlink.project.dto.resp.ShortLinkGroupCountQueryRespDTO;
import com.sky.shortlink.project.dto.resp.ShortLinkPageRespDTO;
import jakarta.servlet.ServletRequest;
import jakarta.servlet.ServletResponse;

import java.util.List;

/**
 * @author Blue sky
 * @Description 短链接接口层
 * @create 2024-02-20 9:58
 */
public interface ShortLinkService extends IService<ShortLinkDO> {

    /**
     * describe 创建短链接
     *
     * @param createReqDTO 创建短链接请求参数
     * @return ShortLinkCreateRespDTO 返回参数对象
     */
    ShortLinkCreateRespDTO create(ShortLinkCreateReqDTO createReqDTO);

    /**
     * 分页查询短链接
     *
     * @param pageReqDTO 分页查询短链接请求参数
     * @return 返回分页对象
     */
    IPage<ShortLinkPageRespDTO> pageShortLink(ShortLinkPageReqDTO pageReqDTO);

    /**
     * 统计同一个gid下短链接数量
     *
     * @param requestParam 请求参数
     * @return 短链接分组查询返回对象list
     */
    List<ShortLinkGroupCountQueryRespDTO> listGroupLinkCount(List<String> requestParam);

    /**
     * 修改短链接
     *
     * @param requestParam 修改请求参数
     */
    void updateShortLink(ShortLinkUpdateReqDTO requestParam);

    /**
     *
     * @param shortUri 原始短链接
     * @param request http 请求
     * @param response http 相应
     */
    void restoreUrl(String shortUri, ServletRequest request, ServletResponse response);

    /**
     * 批量创建短链接
     *
     * @param requestParam 批量创建短链接请求参数
     * @return 批量创建短链接返回参数
     */
    ShortLinkBatchCreateRespDTO batchCreateShortLink(ShortLinkBatchCreateReqDTO requestParam);


    /**
     * 短链接统计
     *
     * @param shortLinkStatsRecord 短链接统计实体参数
     */
    void shortLinkStats(ShortLinkStatsRecordDTO shortLinkStatsRecord);
}
